<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>sorder</title>
  </head>
  <body bgcolor="#FFFFFF">
    <center>Scilab Function</center>
    <div align="right">Last update : April 1999</div>
    <p>
      <b>sorder</b> -  computing the order of a discrete-time system</p>
    <h3>
      <font color="blue">Calling Sequence</font>
    </h3>
    <dl>
      <dd>
        <tt>   [Ro(,n,sval,rcnd)] = sorder(meth,alg,jobd,batch,conct,s,Y(,U,tol,  </tt>
      </dd>
      <dd>
        <tt>                             printw,ldwork,Ri))  </tt>
      </dd>
    </dl>
    <h3>
      <font color="blue">Parameters</font>
    </h3>
    <ul>
      <li>
        <tt>
          <b>meth</b>
        </tt>: integer option to determine the method to use:<ul>
          <li>
            <tt>
              <b>=  </b>
            </tt>1 : MOESP method with past inputs and outputs;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>2 : N4SID method.</li>
        </ul>
      </li>
      <li>
        <tt>
          <b>alg</b>
        </tt>: integer option to determine the algorithm for computing the triangular factor of the concatenated block-Hankel matrices built from the input-output data:<ul>
          <li>
            <tt>
              <b>=  </b>
            </tt>1 : Cholesky algorithm on the correlation matrix;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>2 : fast QR algorithm;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>3 : standard QR algorithm.</li>
        </ul>
      </li>
      <li>
        <tt>
          <b>jobd</b>
        </tt>: integer option to specify if the matrices B and D should later be computed using the MOESP approach:<ul>
          <li>
            <tt>
              <b>=  </b>
            </tt>1 : the matrices B and D should later be computed using the MOESP approach;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>2 : the matrices B and D should not be computed using the MOESP approach.<p>
    This parameter is not relevant for meth = 2.
  </p>
          </li>
        </ul>
      </li>
      <li>
        <tt>
          <b>batch</b>
        </tt>: integer option to specify whether or not sequential data processing is to be used, and, for sequential processing, whether or not the current data block is the first block, an intermediate block, or the last block, as follows:<ul>
          <li>
            <tt>
              <b>=  </b>
            </tt>1 : the first block in sequential data processing;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>2 : an intermediate block in sequential data processing;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>3 : the last block in sequential data processing;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>4 : one block only (non-sequential data processing).</li>
        </ul>
      </li>
      <li>
        <tt>
          <b>conct</b>
        </tt>: integer option to specify whether or not the successive data blocks in sequential data processing belong to a single experiment, as follows:<ul>
          <li>
            <tt>
              <b>=  </b>
            </tt>1 : the current data block is a continuation of the previous data block and/or it will be continued by the next data block;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>2 : there is no connection between the current data block and the previous and/or the next ones.<p>
    This parameter is not used if batch = 4.
  </p>
          </li>
        </ul>
      </li>
      <li>
        <tt>
          <b>s</b>
        </tt>: the number of block rows in the input and output block Hankel matrices to be processed.  s &gt; 0</li>
      <li>
        <tt>
          <b>Y</b>
        </tt>: the t-by-l output-data sequence matrix.  Column j of  Y contains the  t  values of the j-th output component for consecutive time increments.</li>
      <li>
        <tt>
          <b>U</b>
        </tt>: (optional) the t-by-m input-data sequence matrix.  Column j of  U  contains the  t  values of the j-th input component for consecutive time increments. Default:    U = [].</li>
      <li>
        <tt>
          <b>tol</b>
        </tt>: (optional) vector of length 2 containing tolerances: tol(1) - tolerance used for estimating the rank of matrices. If  tol(1) &gt; 0,  then the given value of  tol(1)  is used as a lower bound for the reciprocal condition number; an m-by-n matrix whose estimated condition number is less than  1/tol(1)  is considered to be of full rank. If  tol(1) &lt;= 0,  then a default value m*n*epsilon_machine is used, where epsilon_machine is the relative machine precision.<p>
    tol(2) - tolerance used for determining an estimate of the system order. If  tol(2) &gt;= 0,  the estimate is indicated by the index of the last singular value greater than or equal to  tol(2).  (Singular values less than  tol(2)  are considered as zero.) When  tol(2) = 0,  an internally computed default value,  tol(2) = s*epsilon_machine*sval(1), is used, where  sval(1)  is the maximal singular value, and epsilon_machine the relative machine precision. When  tol(2) &lt; 0,  the estimate is indicated by the index of the singular value that has the largest logarithmic gap to its successor.
  </p>
        <p>
    Default:    tol(1:2) = [0,-1].
  </p>
      </li>
      <li>
        <tt>
          <b>printw</b>
        </tt>:(optional) switch for printing the warning messages.<ul>
          <li>
            <tt>
              <b>=  </b>
            </tt>1:  print warning messages;</li>
          <li>
            <tt>
              <b>=  </b>
            </tt>0:  do not print warning messages.</li>
        </ul>
        <p>
    Default:    printw = 0.
  </p>
      </li>
      <li>
        <tt>
          <b>ldwork</b>
        </tt>: (optional) the workspace size. Default : computed by the formulas<pre>

nr = 2*( m + l )*s
LDWORK = ( t - 2*s + 3 + 64 )*nr
if ( CSIZE &gt; MAX( nr*nr + t*( m + l ) + 16, 2*nr ) ) then
   LDWORK = MIN( LDWORK, CSIZE - nr*nr - t*( m + l ) - 16 )
else
   LDWORK = MIN( LDWORK, MAX( 2*nr, CSIZE/2 ) )
end if
   
          </pre>
        <p>
    LDWORK = MAX( minimum workspace size needed, LDWORK ) where CSIZE is the cache size in double precision words.
  </p>
        <p>
    If LDWORK is specified less than the minimum workspace size  needed, that minimum value is used instead.
  </p>
      </li>
      <li>
        <tt>
          <b>Ri</b>
        </tt>: (optional) if batch = 2 or 3, the 2*(m+l)*s-by-2*(m+l)*s (upper triangular, if alg &lt;&gt; 2) part of  R  must contain the (upper triangular) matrix  R  computed at the previous call of this mexfile in sequential data processing. If conct = 1, R  has an additional column, also set at the previous call.<p>
    If alg = 2,  R  has m+l+1 additional columns, set at the previous call. 
  </p>
        <p>
    This parameter is not used for batch = 1 or batch = 4.
  </p>
      </li>
      <li>
        <tt>
          <b>Ro</b>
        </tt>: if batch = 3 or 4, the 2*(m+l)*s-by-2*(m+l)*s part of  R  contains the processed upper triangular factor  R  from the QR factorization of the concatenated block-Hankel matrices, and further details needed for computing system matrices. If batch = 1 or 2, then  R  contains intermediate results needed at the next call of this mexfile. If batch = 1 or 2 and conct = 1,  R  has an additional column, also set before return. If batch = 1 or 2 and alg = 2,  R  has m+l+1  additional columns, set before return.</li>
      <li>
        <tt>
          <b>n</b>
        </tt>: the order of the system.</li>
      <li>
        <tt>
          <b>sval</b>
        </tt>: (optional) the singular values used for estimating the order of the system.</li>
      <li>
        <tt>
          <b>rcnd</b>
        </tt>: (optional) if meth = 2, vector of length 2 containing the reciprocal condition numbers of the matrices involved in rank decisions or least squares solutions.</li>
    </ul>
    <h3>
      <font color="blue">Description</font>
    </h3>
    <p>
    sorder  - function for computing the order of a discrete-time
    system using SLICOT routine IB01AD.</p>
    <p>
    For one block (data sequences Y, U):
      [R,n,sval,rcnd] = sorder(meth,alg,jobd,4,conct,s,Y,U);</p>
    <p>
    For f blocks (data sequences Yj, Uj, j = 1 : f):</p>
    <pre>

R = sorder(meth,alg,jobd,1,conct,s,Y1,U1);
for j = 2 : f - 1
   R = sorder(meth,alg,jobd,2,conct,s,Yj,Uj,tol,printw,ldwork,R)
end
[R,n,sval,rcnd] = sorder(meth,alg,jobd,3,conct,s,Yf,Uf,tol);
   
    </pre>
    <p>
    sorder preprocesses the input-output data for estimating the matrices 
    of a linear time-invariant dynamical system, using Cholesky or (fast)
    QR factorization and subspace identification techniques (MOESP and
    N4SID), and then estimates the order of a discrete-time realization.</p>
    <p>
    The model structure is :</p>
    <pre>

      x(k+1) = Ax(k) + Bu(k) + w(k),   k &gt;= 1,
      y(k)   = Cx(k) + Du(k) + e(k),
   
    </pre>
    <p>
    where  
    x(k)  is the  n-dimensional state vector (at time k),</p>
    <p>
    u(k)  is the  m-dimensional input vector,</p>
    <p>
    y(k)  is the  l-dimensional output vector,</p>
    <p>
    w(k)  is the  n-dimensional state disturbance vector,</p>
    <p>
    e(k)  is the  l-dimensional output disturbance vector,</p>
    <p>
    and  A, B, C, and D  are real matrices of appropriate dimensions.</p>
    <h3>
      <font color="blue">Comments</font>
    </h3>
    <dl>
      <p>
    1. The Cholesy or fast QR algorithms can be much faster (for large data blocks) than QR algorithm, but they cannot be used if the correlation  matrix, H'*H, is not positive definite. In such a case, the code automatically switches to the QR algorithm, if sufficient workspace is provided and batch = 4.</p>
      <p>
    2. If ldwork is specified, but it is less than the minimum workspace size  needed, that minimum value is used instead.</p>
    </dl>
    <h3>
      <font color="blue">See Also</font>
    </h3>
    <p>
      <a href="findBD.htm">
        <tt>
          <b>findBD</b>
        </tt>
      </a>,&nbsp;&nbsp;<a href="sident.htm">
        <tt>
          <b>sident</b>
        </tt>
      </a>,&nbsp;&nbsp;</p>
    <h3>
      <font color="blue">Author</font>
    </h3>
    <p>   V. Sima, Research Institute for Informatics, Bucharest, Oct. 1999.; ;  Revisions:;    V. Sima, May 2000, July 2000.  </p>
  </body>
</html>
